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TRANSCODERS AND METHODS 



CROSS-REFERENCE TO RELATED APPLICATIONS 

The following cofiled US patent applications disclose related subject matter: 
Appl.Nos.: 10/..., filed ...; 10/..., filed ...; ... The following copending US patent 
application discloses related subject matter: Appl. No.: 09/089,290, filed 6/1/1998. All 
of these referenced applications have a common assignee with the present 
application. 

BACKGROUND OF THE INVENTION 

The present invention relates to digital video image processing, and more 
particularly, to methods and systems for transcoding from one video format to 
another with differing resolution. 

Currently, a large body of video content exists as MPEG-2 encoded bitstreams 
ready for DVD or broadcast distribution. This MPEG-2 content is usually available at 
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(704x480 pixels). However, for effective video transmission, many applications such 
as 3G wireless infrastructure, video streaming, home networking, et cetera use low 
bitrate, progressive standards such as MPEG-4 or H.263. Due to the potential high- 
volume market associated with these applications, video transcoding which can 
convert MPEG-2 bitstreams into MPEG-4 bitstreams is an important, emerging 
technology. 

Figure 2a shows generic DCT-based motion-compensated encoding which is 
used in MPEG-2 and MPEG-4. Figure 2b illustrates a straightforward, but 
computationally intensive, resolution-reducing transcoder for conversion of an MPEG- 
2 bitstream into a lower-resolution MPEG-4 bitstream; the first row of operations 
decodes the input MPEG-2 bitstream, the middle operation down-samples the 
reconstructed video frames by a factor of two in both vertical and horizontal 
dimensions, and the bottom row performs MPEG-4 encoding. In particular, the input 
MPEG-2 SDTV bitstream is decoded by a conventional decoder that performs 
Variable-Length Decoding (VLD), Inverse Quantization (IQ), Inverse Discrete Cosine 
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Transform (IDCT), and Motion Compensation (MC) to produce SDTV-resolution raw 
frames in the 4:2:0 format. Spatial down-sampling by a factor of two is then 
performed vertically and horizontally to produce raw frames. Spatial downsampling 
along the vertical dimension is performed by extracting the top field of the raw 
interlaced SDTV frame. Spatial downsampling along the horizontal dimension is 
subsequently implemented either by discarding odd-indexed pixels or by filtering 
horizontally with the [1; 1] kernel and then discarding the odd-indexed pixels. This 
spatial downsampling yields raw frames at the resolution 352x240. These frames are 
converted to CIF resolution by appending a 352x48 block of zeros to each raw frame. 
Next, the CIF-resolution raw frames are input to an MPEG-4 encoder that performs 
Motion Estimation (ME), Discrete Cosine Transform (DCT), Quantization (Q) and 
Variable-Length Coding (VLC) to obtain the transcoded MPEG-4 CIF bitstream. 

However, because the CIF-resolution frames are obtained from down- 
sampling the SDTV-resolution frames, the motion field described by the MPEG-4 
motion vectors is a downsampled version of the motion field described by the MPEG- 
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because MPEG-2 motion vectors may be re-used in the MPEG-4 encoder, as 
suggested in Figure 3a. In fact, if the ME utilizes an exhaustive search to determine 
the motion vectors, then it consumes approximately 70% of the MPEG-4 encoder 
cycles. In this case, elimination of the ME stage by estimating the MPEG-4 motion 
vectors from the MPEG-2 motion vectors will significantly improve transcoding 
performance. 

Now, every MPEG-2 frame is divided into 16x16 MacroBlocks (MBs) with the 
16x16 luminance pixels subdivided into four 8x8 blocks and the chrominance pixels, 
depending upon format, subsampled as one, two, or four 8x8 blocks; the DCT is 
performed on 8x8 blocks. Each macroblock is either intra- or inter-coded. The 
spatial downsampler of Figure 3a converts a "quartet" of four MBs that are co-located 
as shown in Figure 3b into a single 16x16 Macroblock that will be MPEG-4 encoded. 
Each inter-coded MB is associated with a motion vector that locates the reference 
macroblock in a preceding anchor-frame. Therefore, every MB quartet has four 
associated MPEG-2 motion vectors as shown in Figure 3c. And the prediction errors 
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from use of the reference macroblock as the predictor is DCT transformed; for 
luminance either as four 8x8 blocks according to spatial location (frame-DCT) or as 
four 8x8 blocks with two 8x8 blocks corresponding to the top field of the MB and two 
8x8 blocks corresponding to the bottom field of the MB (field-DCT). 

To eliminate the MPEG-4 ME stage in the Figure 2b baseline transcoder, 
estimate the MPEG-4 motion vector from the four associated MPEG-2 motion 
vectors, as shown in Figure 3c. (Note that in B-frames, an MB may also have an 
additional motion vector to locate a reference macroblock in a subsequent anchor- 
frame.) And various motion vector estimation approaches have been proposed; for 
example, Wee et al., Field-to-frame transcoding with spatial and temporal 
downsampling, IEEE Proc. Int. Conf. Image Processing 271 (1999) estimate the 
MPEG-4 motion-vector by testing each of the four scaled MPEG-2 motion vectors 
associated with a macroblock quartet on the decoded, downsampled frame that is 
being encoded by the MPEG-4 encoder. The tested motion vector that produces the 
least residual energy is selected as the estimated MPEG-4 motion vector. 
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coded, quantized DCT coefficients. However, after the IDCT stage, spatial-domain 
processing accounts for most of the intermediate processing. Finally, the DCT stage 
returns the spatial-domain pixels to the frequency-domain for quantization and VLC 
processing. Some researchers suggested that the intermediate processing can be 
performed in the frequency domain, thus eliminating the IDCT and DCT stages in the 
transcoder. For example, Assuncao et al, A Frequency-Domain Video Transcoder for 
Dynamic Bit-Rate Reduction of MPEG-2 Bit Streams, 8 IEEE Trans. Cir. Sys. Video 
Tech. 953 (1998). 

And Merhav et al, Fast Algorithms for DCT-Domain Image Down-Sampling 
and for Inverse Motion Compensation, 7 IEEE Tran. Cir. Sys. Video Tech. 468 
(1997), provides matrices for downsampling and inverse motion compensation in the 
frequency domain together factoring of the matrices for fast computations. 

Further, Song et al, A Fast Algorithm for DCT-Domain Inverse Motion 
Compensation Based on Shared Information in a Macroblock, 10 IEEE Trans. Cir. 
Sys. Video Tech 767 (2000), disclose inverse motion compensation taking advantage 
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of the adjacent locations of the four reference 8x8 blocks of a predicted macroblock 
to simplify the computations. 

Subsequently, Liu et al, Local Bandwidth Constrained Fast Inverse Motion 
Compensation for DCT-Domain Video Transcoding, 12 IEEE Tran. Cir. Sys. Video 
Tech. 309 (2002) and A Fast and Memory Efficient Video Transcoder for Low Bit 
Rate Wireless Communications, IEEE Proc. Int. Conf. ASSP 1969 (2002), 
demonstrated reduced-complexity frequency-domain transcoding by downsampling 
prior to inverse motion compensation in the frequency domain. 

Arai et al, A Fast DCT-SQ Scheme for Images, 71 Trans. IEICE 1095 (1988), 
provides a factorization for the 8x8 DCT matrix which allows for fast computations. 

Hou, A Fast Recursive Algorithm for Computing the Discrete Cosine 
Transform, 35 IEEE Tran. ASSP 1455 (1987), provides a recursive method for the 
DCT analogous to the fast Fourier transform (FFT) in which a 2N-point transform is 
expressed in terms of N-point transforms together with simple operations. 
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The present inventions provide resolution-reducing transcoding methods 
including motion vector reuse by best predictor selection, motion vector refinement by 
search window adaptation to reference block boundary alignment, frequency domain 
downsampling with frame-DCT blocks spatially averaged but field-DCT blocks 
spatially averaged only horizontally and the field averaged, and mixtures of one- 
dimensional de-interlacing IDCT with IDCT plus downsampling. 

BRIEF DESCRIPTION OF THE DRAWINGS 
The drawings are heuristic for clarity. 
Figures 1a-1d are flow diagrams. 

Figures 2a-2b show motion compensation encoding and a transcoder. 

Figures 3a-3d illustrate a transcoder and motion vector estimation. 

Figures 4a-4b show transcoders. 

Figures 5a-5c illustrates motion vector refinement. 

Figure 6 is another transcoder. 
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1 I. 



DESCRIPTION OF THE PREFERRED EMBODIMENTS 



1 . Overview 

The preferred embodiment methods and systems convert MPEG-2 bitstreams 
into MPEG-4 bitstreams with spatial-resolution reduction by downsampling. The 
methods include re-use of motion vectors for downsampled blocks by scaling the best 
predictor of four motion vectors prior to downsampling, refinement of motion vector 
estimates in the frequency domain by search windows which adapt to target and 
reference block boundary alignment, B-picture and l-/P-picture separate 
downsampling methods, and mixture of de-interlacing one-dimensionai (1-D) inverse 
DCT (IDCT) and 1-D IDCT plus downsampling together with inverse motion 
compensation after horizontal downsampling but prior to vertical downsampling in 
order to minimize drift. 



2. Motion Vector Estimation 
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transcoding MPEG-2 to MPEG-4, first briefly consider following five prior art 
approaches: 

(1) random motion-vector estimation: The simplest motion-vector estimation 
algorithm for downsampled frames is the random algorithm proposed by Shanableh 
et al, Heterogeneous Video Transcoding to Lower Spatio-Temporal Resolutions and 
Different Encoding Formats, 2 IEEE Trans. On Multimedia 1927 (2000). To obtain 
the MPEG-4 estimate, the algorithm randomly selects one of the four MPEG-2 motion 
vectors in Figure 3c and then halves its horizontal and vertical components. This 
scaling of the motion-vector components is done to account for the spatial-resolution 
difference between the MPEG-2 frame and the MPEG-4 frame. If a processor clock is 
used to select a random number, then the random motion-vector estimation algorithm 
has a very low cycle count. 

(2) average motion-vector estimation: Shen et al., Adaptive Motion-Vector 
Resampling for Compressed Video Downscaling, 9 IEEE Trans. Cir. Sys. Video 
Tech. 929 (1999) and Shanableh et al, supra, proposed that the MPEG-4 motion- 
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vector estimate may be obtained by separate averaging of the horizontal and vertical 
components of the four MPEG-2 motion vectors. The averaged motion vector is then 
scaled to account for the spatial-resolution reduction. This algorithm consumes 6 
adds and 2 shifts. 

(3) weighted-average motion-vector estimation: Shen et al., supra, and Yin et al. 
Video Transcoding by Reducing Spatial Resolution, IEEE Proc. Int. Conf. Image 
Processing 972 (2000) showed that the performance of the average motion vector 
estimation algorithm may be improved by adaptively weighting the average so as to 
move the estimate toward motion vectors associated with MBs containing edges. 
The cycie count for this algorithm is 76 adds and two shifts, assuming that 25% of the 
DCT terms in the four MPEG-2 macroblocks are non-zero. 

(4) median motion-vector estimation: Shanableh et al, supra, demonstrated that the 
median of the four MPEG-2 motion vectors may be used as the MPEG-4 motion 
vector estimate. The median is obtained by first calculating the distance between 
each MPEG-2 motion vector and the rest. Next, the median motion vector is defined 
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vector is scaled to obtain the MPEG-4motion-vector estimate. The median motion- 
vector estimation algorithm requires 30 adds, 12 multiplies, two shifts and three 
comparisons. 

(5) minimum-norm motion-vector estimation: Wee et al., cited in the background, 
estimate the MPEG-4 motion-vector by testing each of the four scaled MPEG-2 
motion vectors associated with a macroblock quartet on the decoded, down-sampled 
frame which is being encoded by the MPEG-4 encoder. The tested motion vector 
that produces the least residual energy is selected as the estimated MPEG-4 motion 
vector. The cycle count for this algorithm is 256 adds, three comparisons and two 
shifts. 

The first preferred embodiment motion vector estimation method is a fast 
minimum-norm motion-vector estimation which may be used in transcoders that 
reduce the output bitrate by discarding B-frames as in Wee et al. As shown in 
Figures 3b-3c, for a quartet of MPEG-2 macroblocks there are four MPEG-2 motion 
vectors, one motion vector is associated with each MPEG-2 macroblock. For each of 
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these four macroblocks, compute the sum of squares of all (non-zero) entries in the 
corresponding DCT residual blocks (recall DCT is on 8x8 blocks). This quantity is the 
squared I 2 norm of the residual block; and for P-frame macroblocks, this norm serves 
as a figure of merit for the motion vector associated with the macroblock. Indeed, a 
small I 2 norm indicates low residual energy which, in turn, implies that the associated 
motion vector points to a reference block that is an effective predictor for the 
macroblock. Next, select among these four MPEG-2 motion vectors the one 
associated with the macroblock having the smallest I 2 norm. Then halve this motion 
vector to account for the downsampling resolution reduction, and use the thus-scaled 
motion vector as the estimate for the MPEG-4 motion vector; see Figure 1a. Note 
that the I 2 norms may be estimated quickly because there typically are few non-zero 
entries in the DCT residual blocks due to quantization; and these entries are made 
explicit during the MPEG-2 decoder's VLD operation. This preferred embodiment 
method of motion vector estimation consumes 64 adds, three comparisons and two 
shifts, assuming that 25% of the DCT terms in the four MPEG-2 residual MBs are 
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In more mathematical terms the foregoing can be described as follows. First, 
presume the four macroblocks x<\, x 2 , x 3j form a 2x2 quartet of macroblocks and 
were MPEG-2 compressed to yield the four motion vectors vz v 3 , v 4 , together with 
the corresponding quantized 8x8 DCTs; the number of DCTs depends upon the 
macroblock format: six for 4:2:0, eight for 4:2:2, or twelve for 4:4:4. For each n the 
motion vector v n was determined by searching to minimize the prediction error, e n , of 
the 16x16 luminance part, y n , of macroblock x n . That is, the motion vector v n locates 
the predicted 16x16 luminance block y u from the prior reconstructed reference frame 
which minimizes the 16x16 prediction error e n = y n - j> n . Now, for each n, the 16x16 
e n can be viewed as a 2x2 array of 8x8 prediction errors: <? n ,i, *n,2, <?n,3, ^m; and the 
corresponding quantized 8x8 DCTs, E n ,u E u%2y £ n ,3, £n,4, are four of the 8x8 DCTs that 
were generated by the MPEG-2 motion compensation and compression. 

Next, downsample the quartet of (reconstructed) macroblocks, jci, *2, *3, **, by 
a factor of 2 in each dimension to yield a single macroblock x which is to be MPEG-4 
compressed. Preferably, the downsampling occurs in the frequency domain. The 
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MPEG-4 compression includes finding a motion vector, v, for x which locates a 16x16 
luminance prediction y from a prior reconstructed reference frame. 

The preferred embodiment method estimates this motion vector v by the 
following steps. 

(i) Compute the four squared norms ||£i|| 2 , \\E 2 \\, ||^3|| 2 , ||^4|| 2 where ||£ n || 2 = 
||£n,i|| 2 + H^rdl 2 + ll^n.all 2 + H^mII 2 with ||£ n ,k|| 2 = Io<ij<7 ^n,k;i,j 2 the sum of squares of 
the 64 elements of E n ^. Due to quantization, a large number of the 64 elements 
vanish. 

(ii) Pick n so that ||£ n || 2 is the smallest of the four squared norms from step (i). 

(iii) Estimate the motion vector v by v n /2 where n was determined in step (ii). Thus 
when v n has half-pixel accuracy, v will have quarter-pixel accuracy. Of course, 
fractional-pixel motion vectors corresponds to a prediction block resulting from linear 
interpolation of the closest integer-pixel motion vector located blocks. 

Note that the E n ^ and the v n are available from the input MPEG-2 compression 
of the quartet of macroblocks, so the computations have low complexity. 
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derived from the luminance part, so there is no further motion vector to estimate. 
Also, field rather than frame compression may generate two motion vectors, but treat 
each field motion vector as in the foregoing. And if one (or more) of the quartet of 
macroblocks is skipped or not encoded, then its corresponding E n will be all Os and 
have the smallest squared norm in step (ii); thus the computation of step (i) can be 
skipped. Lastly, B-pictures have been omitted to reduce bitrate, but the same 
preferred embodiment methods could apply to the motion vectors for B-pictures. 

Variations of the preferred embodiment motion vector estimation methods 
include use of a different magnitude measure in place of the squared norm to 
measure the magnitude of the DCT of the prediction errors, such as P norms, 
although the DCT is not an isometry with respect to such norms for p 1 2. Further, 
NxN arrays of macroblocks for downsampling by a factor of N in each dimension 
could be used with N greater than 2; and then the minimum-norm motion vector 
components are divided by N. Figure 1a illustrates the methods. 
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3. Motion Vector Estimation Experimental Results 

To compare the performance of the preferred embodiment motion vector 
estimation with the various other motion-vector estimation methods, each of the 
methods was used in the transcoder of Figure 3a. Then the PSNR-loss/frame 
between the transcoded frames with estimated motion vectors and the downsampled 
output in the baseline transcoder of Figure 2b was evaluated. The average PSNR- 
loss per frame (in dB) for the methods were as follows. 



Random 5.62 

Average 8.21 

Weighted average 7.46 

Median 1 .34 

Minimum norm 0 

Preferred embodiment 0.58 



The median, minimum-norm and preferred embodiment methods have acceptable 
performance. Based on the cycle counts provided for the methods, order these three 
algorithms from lowest to highest computational complexity as follows: median < 
preferred embodiment < minimum-norm. Because the minimum norm method has 
very high computational complexity, the median and the preferred embodiment 
motion-vector estimation methods provide the best performance with a trade-off of 
low complexity (median) for accuracy (preferred embodiment). 

4. Frequency-Domain Transcoding 

Figure 3a shows the transcoder input and output bitstreams are coded, 
quantized DCT coefficients. However, after the IDCT stage, spatial-domain 
processing accounts for most of the intermediate processing. Finally, the DCT stage 
returns the spatial-domain pixels to the frequency domain (DCT domain) for 
quantization and VLC processing. Prior researchers such as Chang et al, 
Manipulation and Compositing of MC-DCT Compressed Video, 13 IEEE J. Sel. Areas 
Comm. 1 (1995), Assuncao et al, Transcoding of MPEG-2 Video in the Frequency- 
Domain, IEEE Proc. Int. Conf. ASSP 2633 (1997), and Merhav et al, cited in the 
background, suggested that the intermediate processing can be performed in the 
frequency domain, thus eliminating the IDCT and DCT stages in the transcoder, and 
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the preferred embodiments extend such methods. Thus first consider these prior 
frequency-domain transcoding methods. 

Chang et al, Manipulation and Compositing of MC-DCT Compressed Video, 
13 IEEE J. Sel. Areas Comm. 1 (1995), showed that motion compensation can be 
performed in the frequency domain (DCT-domain). Their algorithm was improved 
upon by Merhav et al and Assuncao et al, both cited in the background, who showed 
in addition that frequency domain motion compensation may be used in a frequency- 
domain transcoder. However, unlike the baseline transcoder in Figure 2b, the 
transcoder of Assuncao et al provided bitrate reduction but did not perform a spatial- 
resolution reduction. Subsequently, Lin et al, Fast Algorithms for DCT-Domain Video 
Transcoding, IEEE Proc. Int. Conf. Image Processing 421 (2001), used partial low- 
frequency extraction to reduce the computational complexity of the transcoder of 
Assuncao et al. 

Natarajan et al, A Fast Approximate Algorithm for Scaling Down Digital Images 
in the DCT Domain, IEEE Proc. Int. Conf. Image Processing 241 (1995), proposed a 
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be used to modify the transcoder of Assuncao et al as shown in Figure 4a to obtain a 
frequency domain transcoder with spatial-resolution reduction. In Figure 4a the top 
row of operations is MPEG-2 processing and the bottom row of operations is MPEG- 
4 processing. The MC stage implements frequency-domain motion compensation, 
and the Downsample stage performs spatial-resolution reduction in the frequency 
domain. However, this approach to frequency-domain transcoding wastes, 
computational cycles because the MPEG-2 decoder performs a computationally 
expensive MC operation at the high SDTV resolution. 

Instead, based on the observation of Mokry et al, Minimal Error Drift in 
Frequency Scalability for Motion-Compensated DCT Coding, 4 IEEE Tran. Cir. Sys. 
Video Tech. 302 (1994), that the MC and Downsample stages are interchangeable, 
Vetro et al. Minimum Drift Architectures for 3-Layer Scalable DTV Decoding, 44 IEEE 
Cons. Elec. 527 (1998), suggested the transcoding scheme shown in Figure 4b, 
again with the top row of operations for MPEG-2 processing and the bottom row of 
operations MPEG-4 processing. In this frequency-domain transcoder, the frequency 
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domain frames are downsampled to the low CIF resolution and then motion 
compensated in the DCT domain. Because the computationally expensive MC stage 
is performed at the lower CIF resolution, the computational complexity is significantly 
reduced. Two separate MC stages are required because the decoder and encoder 
have different frame formats: the MPEG-4 encoder supports only I- and P-frames, but 
the MPEG-2 decoder also uses B-frames. Subsequently, Vetro et al., Generalized 
Motion Compensation for Drift Minimization, SPIE Conf. Vis. Comm. Image 
Processing (vol.3309 1998), Yin et al, Drift Compensation Architectures and 
Techniques for Reduced Resolution Transcoding, SPIE Conf. Vis. Comm. Image 
Processing (voi.4671 , 2002), and Shen et al, A Very Fast Video Spatial Resolution 
Reduction Transcoder, IEEE Proc. Int. Conf. ASSP 1989 (2002), proposed variants of 
the frequency-domain transcoder depicted in Figure 4b. However, these methods 
are computationally complex because the downsampled l/P-frames are upsampled 
before motion compensation to reduce drift. 

Subsequently, Liu et al, cited in the background, demonstrated reduced- 
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transcoder of Liu et al is 50% more memory efficient and 70% less computationally 
complex than other approaches, it has two significant disadvantages: (1) the 
frequency domain motion-compensation method uses an 800 Kb lookup table that is 
impractical for DSP implementation, and (2) only progressive prediction formats are 
decoded efficiently; field prediction is computationally expensive. 

The first preferred embodiment frequency-domain transcoding methods also 
use a Figure 4b type transcoder with input an MPEG-2 bitstream and VLD, IQ, and 
frequency domain downsampling followed by frequency domain inverse motion 
compensation (reconstruction) to convert all inter blocks to intra blocks. The intra 
frames are then encoded by a frequency domain MPEG-4 encoder that outputs the 
transcoded MPEG-4 bitstream. And to overcome drawbacks (1)-(2) of the transcoder 
of Liu et al, the preferred embodiment methods (1) use a macroblock shared 
information method similar to the Song et al method cited in the background and (2) 
have separate frame/field prediction approaches as illustrated in Figure 1b. 
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In particular, for the first preferred embodiment frequency domain 
downsampling methods frame-DCT block downsampling differs from field-DCT block 
downsampling. For frame-DCT blocks, downsample the blocks in the frequency 
domain similar to Merhav et al, cited in the background. This method performs 
vertical downsampling by a frequency-domain operation that is equivalent to spatial 
averaging of the top and bottom fields of each block. Horizontal downsampling is 
achieved by a frequency-domain operator that averages the spatial-domain even- 
and odd-polyphase components of each row. 

For field-DCT blocks, the top and bottom field DCT blocks are provided 
separately in MPEG-2. So first downsample horizontally separately for the DCT 
blocks of the top- and bottom-fields again with a method similar to that of Merhav et 
al, cited in the background. Next, downsample vertically by averaging the 
horizontally-downsampled top- and bottom-field DCT blocks. Applying different 
downsampling operators to the frame-DCT and field-DCT blocks yields a frequency 
domain downsampling method that efficiently computes the DCT of the field- 

fields of interlaced video are highly correlated, the field-averaged DCT blocks may be 
used for frame-prediction as well as for field-prediction. Experiments show that very 
few noticeable artifacts arise after performing motion compensation on the field- 
averaged DCT blocks. These artifacts occur in the field-predicted blocks that have 
top- and bottom-fields that differ significantly. To prevent the propagation of any such 
artifacts in the encoder, the preferred embodiment methods may store the location of 
field-predicted blocks. During the encoder's mode-decision stage, blocks with motion 
vectors pointing to field-predicted blocks are coded as intra blocks. This prevents 
any artifacts in field-predicted blocks from propagating to subsequent frames. This 
method of preventing artifact propagation is a simplified implementation of Vetro et 
al.'s intra-refresh technique. 

For a more explicit version of the foregoing, again presume the four inter- 
coded macroblocks jci, x 2 , * 3 , x 4 form a 2x2 quartet of macroblocks and were MPEG- 
2 compressed to yield the four motion vectors vi, vz v 3 , v 4 together with the 
corresponding quantized 8x8 DCTs; the number of DCTs depends upon the 
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macroblock format: six for 4:2:0, eight for 4:2:2, or twelve for 4:4:4. For each n the 
motion vector v n was determined by searching to minimize the prediction error, e n , of 
the 16x16 luminance part,^ n , of macroblock x n . That is, the motion vector v„ locates 
the predicted 16x16 luminance block j> n from the prior reconstructed reference frame 
which minimizes the 16x16 prediction error e„ = y n -y n . Now, each 16x16 e n can be 
viewed as a quartet of 8x8 prediction errors: «„,i, « n ,2, «iu> e nA', and the corresponding 
quantized 8x8 DCT blocks, E nA , E n<2 , E n ,z, E nA , are four of the 8x8 DCTs that were 
generated by the MPEG-2 compression. Let^n denote the 16x16 block composed of 
the four 8x8 E nM arranged in the same pattern as the e„,i, em, e n j, e nA form e n . 

Of course, if macroblocks xi, x 2 , xz, x 4 were intra-coded, then there would be 
no motion vectors and the luminance parts, y-\,y2, yz, ^4, would each be viewed as a 
quartet of 8x8 luminance blocks (y n as the quartet ^,1,^,2,^,3,^11,4) ar| d eachy n , k is 
transformed (8x8 DCT) to F n , k for encoding. Similar DCT blocks come from the 
chrominance blocks. 

The approach of Liu et al for downsampling in the frequency domain by a 
factor of 2 in each dimension converts the quartet of (reconstructed) rnacrobiocks, xi, 
X2, xz, x 4 , into a single macroblock x which is to be MPEG-4 compressed as follows. 
First, for each of the four 8x8 DCTs, £ n ,k (k = 1 ,2,3,4), from E n , take only the upper left 
(low frequency) 4x4 DCT coefficients, and combine these four 4x4s to form a single 
8x8 DCT block, £.,„. Then these four DCT blocks (n = 1 ,2,3,4) are taken as E, the 
DCT blocks for the prediction error e of the luminance part,y of downsampled 
macroblock x. For intra-coded frames the same approach applies, but using the 
luminance in place of the luminance prediction error; namely, for each of the four 8x8 
DCT blocks, F n ,k (k = 1 ,2,3,4), from F„, take only the upper left (low frequency) 4x4 
DCT coefficients, and combine these four 4x4s to form a single 8x8 DCT block, K n . 
Then these four 8x8 DCT blocks (n = 1 ,2,3,4) are taken as F, the DCT blocks for the 
16x16 luminance part.y of downsampled macroblock*. Again, the chrominance 
blocks are treated analogously. 

As illustrated in Figure 1b, the first preferred embodiment frequency domain 
methods downsample in the frequency domain by adapting the downsampling to the 



TI-35495/35498/35514/35515/35536/35537 Page 13 



incoming prediction format (frame-DCT blocks or field-DCT blocks for MPEG-2) as 
follows. 

Frame-DCT blocks. Presume four 8x8 blocks x\ , x 2 , x 3 , x* in the spatial 
domain which are located as a 2x2 array forming a 16x16 block that is to be 
downsampled by a factor of 2 in each dimension to yield an output 8x8 block x; these 
blocks may be either prediction errors (residuals) of an inter-coded picture or blocks 
of pixels of an intra-coded picture. The preferred embodiment downsampling first 
averages pairs of pixels in the vertical direction and then averages pairs of the prior 
averages in the horizontal direction. This can be written in 8x8 matrix format as: 

x={Q^x^ + x 2 Qz + Qz x 2 + Q 2 x 4 Q 2 )/4 
where superscript t denotes transpose and the 8x8 matrics Q\ and Q 2 are: 

"1 1 0 0 0 0 0 0" 
0 0 1 1 0 0 0 0 
0 0 0 0 1 1 0 0 
0 0 0 0 0 0 1 1 
000000 0 0 
00000000 
00000000 
00000000 



and Q 2 = 



1 


1 


0 


0 


0 


0 


0 


0 


0 
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0 


0 
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0 
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0 
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1 
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0 
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0 


0 


0 


1 


1 


0 


0 


0 


0 


0 
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0 


0 
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0 


0 


0 
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0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 



Note that the left multiplication by Q k averages pairs vertically and that the right 
multiplication by Q* averages pairs horizontally. Now let A* denote the 8x8 DCT of x k ; 
that is, A* = Sx^ where S is the 8x8 DCT matrix. Because S is orthogonal, S~ : = 5 1 
and 5* is explicitly given by: 
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0.1913 


-0.0975 



Further, let U\ and U 2 denote the frequency domain versions of Q\ and Q 2 , 
respectively; that is, U: = SQ^S~^ and U 2 - SQ 2 S~\ 

Now taking the DCT of the foregoing spatial domain downsampling expression 
yields the corresponding frequency domain downsampling expression: 

X=(UiX- l Uf + U, X 2 U 2 { + U 2 X 3 + U 2 X 4 U 2 X )/4 
Thus the four input 8x8 DCT blocks {X k ) determine the downsampled output 8x8 DCT 
block (X) by matrix operations with the t/ k matrices. This approach has low 
computational complexity due to the possibility of factoring the matrices to simplify 
the matrix operations. In particular, make the following definitions: 

X+++ - Xi + X 2 + Xz + Xa 

X+— - X-\ + X 2 - Xz - X4 

X-*- = X-\ - X 2 + X$ - X4 

X + = X-[ - X 2 — Xz + A4 
Note that these combinations require at most only eight additions/subtractions per 
frequency component. Then, with these combinations the expression for X becomes: 

X = ( U+ t/ + l + U- AT + _ U + l + U* X- + - UJ + U- X_ + U- X )/1 6 
where £/+ = U\ + U 2 and U- = (7i - U 2 . These two combination matrices factor as U+ = 
DPB : B 2 F + B 2 *B^r : D x and U. = DPB^ B 2 F. B 2 A B^r^D x where the matrices 
D, P, B^, B 2 , F-, and F + are listed in the following; this factoring provides for fast 
computations and ultimately derives from Arai et al, cited in the background. Note 
that D is a diagonal 8x8 matrix and the off-diagonal 0s have been omitted for clarity. 
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Field-DCT blocks. The 16x16 luminance part of a macroblock in field-DCT 
coding consists of two horizontally-adjacent 8x8 blocks which make up the top field 
(16 columns by 8 rows) and the two corresponding 8x8 blocks of the bottom field, so 
the resulting four 8x8 DCT blocks consist of two from the top field and two from the 
bottom field. Reconstruction vertically interlaces these blocks after IDCT. More 
particularly, denote the four 8x8 luminance field blocks as ^° p u^° p 2, x bo, 3, x*°4 which, 
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when interlaced, form a 16x16 block that is to be downsampled by a factor of 2 in 
each dimension to yield an output 8x8 block x. Again, these blocks may be either 
inter-coded field prediction errors or intra-coded field pixels; and denote the 
corresponding 8x8 DCT blocks as X t0 %X"" , 2 , A* 0, 3 , which are encoded in the 
MPEG-2 bitstream. The preferred embodiment downsampling first averages pairs of 
pixels in the horizontal direction and then averages the top and bottom fields. That is: 

x*» = QS + x top 2 Q 2 i )l2 

x bo, = {x bot iQ< l i + x bo UQz )/2 

x ={x ,op + x bot )/2 
Again, to have this downsampling in the frequency domain, apply DCT: 

X top = {X top - i U\ + A*" p 2 U 2 )/2 

X bo <=(X bot 3US + X bo UU 2 x )l2 

X ={X" ,p +X bot )I2 
And as previously noted, the matrices factor to simplify the computations. In 
particular, £/ k = DPB A B 2 MA\ A 2 A 3 Q k A^A 2 '^ /If 1 Ar 1 5 2 ~ 1 £f ^D -1 where 
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After the downsampling in the frequency domain, the Figure 4b transcpder 
structure requires (inverse) motion compensation (reconstruction) in the frequency 
domain which converts inter-coded frames/fields into intra-coded frames/fields in 
order to then apply MPEG-4 encoding (with estimated motion vectors as in section 2). 
The preferred embodiments use an inverse motion compensation method which 
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takes advantage of correlations between blocks of a macroblock to lower 
computational cost; see the Song et al reference in the background. In particular, 
Figure 3d illustrates prediction of each of 8x8 blocks Q M , Q N , Q T , Q u from their 
corresponding 16x16 anchor blocks M, N, T, and U where M is made up of the four 
8x8 blocks M 0( Ml M 2 , and M 3 ; N is made up of the four 8x8 blocks N 0 , Ni, N 2> and 
N 3 ; and analogously for T and U. As Figure 3c shows, the 16x16 anchor blocks have 
common 8x8 blocks: Mi is the same as N 0 , and M 3 , N 2 , Ti, and U 0 are all the same 
8x8 block; et cetera. Now the single motion vector for Q locates the 8x8 reference in 
M for Q M , the 8x8 reference in N for Q N , the 8x8 reference in T for Q T , and the 8x8 
reference in U for Q u . Thus the horizontal and vertical displacements of the 8x8 
reference for Q M within M are the same as the displacements of the Q N reference 
within N, the displacements of the Q T reference within T, and the displacements of 
the Q u reference within U. This identity of displacements allows for rearrangement of 
the inverse motion compensation computations as follows. 

First some notation: let P ref denote an 8x8 reference block made from the four 

Mciyiiuwmiy (jao uiu^a ro, r-|, r 2 , r 3 , una uaii uc wnueii in oao illdllix lUimai db" r re f 

= Iosjs 3 SjiPjS j2 with Sji and S j2 8x8 matrices like: 



L n = 



®($-n)xn ^(S-n)x(S-n) 



or R n = 



^/u(8-/i) I/wn 
_0(8-n)x(8-/i) 0/k(8-/i) 



where is an nxn identity matrix and 0 tom is a kxm 0 matrix. For example, for Sji of 
the form L n and S j2 of the form R m , SjiPjS j2 is an 8x8 matrix with the lower right nxm 
block the same as the upper left nxm block of Pj and the remaining elements all equal 
toO. 

With this notation, Q M = £ 0 <£ 3 SjiMjS j2 for appropriate S jk (determined by the 
motion vector) and Q N = Xo<js 3 SjiNjS j2 with the same S jk because of the same relative 
locations in the reference macroblock (same motion vector). Similarly, Q T and Q u 
also use the same S jk . This reflects the four 8x8 blocks making up the macroblock Q 
all have the same motion vector. 

Next, these four sums can each be rewritten by adding and subtracting terms; 
and this can reveal duplicative computations among the four sums. In particular, 
Q M = Zo^sa SjiMjSj 2 
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= Soi(M 0 - Mi - M 2 + M 3 )S 0 2 + So^Mi - M 3 )P° 
+ P 1 (M 2 -M3)So2 + P 1 M 3 P 0 .. 
where P° = S02 + Si 2 is a permutation matrix because S02 and S12 move columns in 
opposite directions and have complementary size, and similarly P 1 = S01 + S31 is 
another permutation matrix. Similarly, Q N yields 

Q N = Zosj£3 SjiNjSj2 

= S 0 i(Ni - No - N 3 + N 2 )Si2 + Soi(N 0 - N 2 )P° 
+ P 1 (N 3 - N 2 )S 12 + P 1 N 2 P° .. 
And due to No = Mi and N2 = M 3 , the second and fourth terms of this sum are the 
same as second and fourth terms in the sum for Q M , which will allow reuse of 
computations in the following. 
Analogously, 

Q T = Zosjs3 SjiTjSj2 

= S 2 i(T 2 - T 3 - To + T 1 )S 02 + S 2 i(T 3 - Ti)P° 
+ P 1 (T 0 -Ti)So2 + P 1 T 1 P 0 .. 
and Q u = Zo< js3 SjiUjSj 2 

= S 2 i(U 3 - U 2 - U1 + U 0 )S 12 + S 2 i(U 2 - U 0 )P° 
+ P 1 (Ui - U 0 )Si 2 + P 1 U 0 P° .. 
Now to compute DCT(Q M ), DCT(Q N ), DCT(Q T ), and DCT(Q U ), which are the 
four prediction error DCTs, begin with DCT(Q M ) and use the similarity transform 
nature of the DCT to have 
DCT(Q M ) = 

DCT(Soi){DCT(M 0 ) - DCT(Mi) - DCT(M 2 ) + DCT(M 3 )} DCT(S 02 ) 
+ DC^SoiKDC^MO - DCT(M 3 )}DCT(P° ) 

+ DCT(P 1 ){DCT(M 2 )-DCT(M 3 )}DCT(S 02 ) 
+ DCT(P 1 )DCT(M 3 )DCT(P 0 ).. 
Second, compute DCT(Q N ) , 
DCT(Q N ) = 

DCT(S 0 i){DCT(Ni) - DCT(N 0 ) - DCT(N 3 ) + DCT(N 2 )} DCT(Si 2 ) 
+ DCT(Soi){DCT(N 0 ) - DCT(N 2 )}DCT(P°) 
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+ DCT(P 1 ){DCT(N 3 )-DCT(N 2 )}DCT(Si 2 ) 
+ DCT(P 1 )DCT(N 2 )DCT(P 0 ).. 
And as previously noted, N 0 = Mi and N 2 = M 3 , so in the second line of the 
expression for DCT(Q N ) the DCT(S 0 i){DCT(N 0 ) - DCT(N 2 )}DCT(P°) has already been 
computed as DCT(S 0 i){DCT(Mi) - DCT(M 3 )}DCT(P° ) in the second line of DCT(Q M ). 
Similarly, the fourth line of DCT(Q N ), DCT(P 1 )DCT(N 2 )DCT(P°), is the same as the 
fourth line of DCT(Q M ), DCT(P 1 )DCT(M 3 )DCT(P°). Thus the computation of DCT(Q N ) 
can reuse computations from DCT(Q M ). 

Third, compute DCT(Q T ) noting that T 0 = M 2 and Ti = M 3 , so the computations 
can use the equalities P 1 (T 0 - T 1 )S 02 = P 1 (M 2 - M 3 )S 02 and P^^^P 0 = P 1 M 3 P°, and 
thereby reuse computations from DCT(Q M ). 

Fourth, compute DCT(Q U ). Initially, note that U 0 = Ti and U 2 = T 3 , so use 
S 2 i(U 2 - U 0 )P° = S 2i (T 3 - Ti)P° and P 1 U 0 P° = P 1 TiP° and thus reuse terms from the 
third computation. Lastly, note that U 0 = N 2 and Ui = N 3 , so P 1 (Ui - U 0 )Si 2 = P 1 (N 3 - 
N 2 )Si 2 and thus reuse the term from the second computation. 

5. Motion Vector Refinement in the Frequency Domain 

Section 2 described how MPEG-4 motion vectors may be estimated for the 
downsampled macroblocks from the MPEG-2 motion vectors contained in the input 
bitstream. After the estimation, a half-pixel motion-vector refinement has been shown 
to improve the reliability of the estimate. However, such a refinement is difficult to 
implement in frequency-domain transcoders that use the scheme outlined in Figure 
4b. Plompen et al., A New Motion-Compensated Transform Coding Scheme, IEEE 
Proc. Int. Conf. ASSP (1985),. and The Performance of a Hybrid Videoconferencing 
Coder Using Displacement Estimation in the Transform Domain, IEEE Proc. Int. 
Conf. ASSP (1986), suggested a method for frequency-domain motion estimation 
that may also be used for frequency-domain motion-vector refinement. However, 
because their method is based on the Hadamard transform, it is not as 
computationally efficient for frequency domain motion-vector refinement. More 
recently, Liang et al., in cross-referenced patent application No. 09/089,290, filed 
6/1/1998 and published 12/26/2002, proposed a fast algorithm for frequency-domain 
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motion-vector refinement. However, this method is computationally expensive when 
the macroblock is aligned with reference DCT blocks. 

The preferred embodiment motion vector refinement methods apply to the 
Figure 4b frequency-domain transcoder that outputs an MPEG-4 bitstream; the 
MPEG-4 encoder input is a sequence of frames comprised of 8x8 intra DCT blocks. 
The first frame is encoded as an l-frame and each successive frame becomes a P- 
frame that is predicted from the preceding frame. During encoder motion-estimation, 
derive a motion-vector estimate and corresponding figure of merit for each 
macroblock. If the figure of merit indicates a poor motion-vector estimate, then 
perform a 0.5 pixel motion-vector refinement as explained below. To refine the 
motion-vector estimate for a particular 16x16 macroblock, the constituent DCT blocks 
(four for luminance and one or more for each chrominance) are IDCT'd and the 
motion-vector estimate is used to co-locate the macroblock against the DCT blocks in 
the preceding reference frame, as depicted in Figure 5a. If the reference DCT blocks 
covered by the macroblock are IDCT'd, then an 18x18 search window may be used 
for the biiinear inierpoiaiion thai precedes a 0.5 pixel motion-vector refinement. 
Unfortunately, this straightforward approach is computationally expensive; 
consequently, the preferred embodiment methods provide a reduced-complexity 
implementation as follows. 

The alignment of the gray macroblock against the reference DCT blocks in 
Figure 5a creates three cases of interest. In Figure 5a, a (B) measures the 
displacement of the upper (left) macroblock boundary from the nearest, covered, 
upper (left) boundary of a reference 8x8 DCT block. The first case deals with the 
situation in which the macroblock is not aligned with any reference DCT block 
boundaries; therefore, 8>a>0, 8>B>0 and nine reference DCT blocks are 
covered by the macroblock. Now define an 18x18 search window whose alignment 
against the reference DCT blocks is described by a and b, where a = a + 1 and 6 = 3 
+ 1 . This search window also covers only nine reference DCT blocks and the pixels 
in the window may be obtained from these blocks using Liang et al.'s fast algorithm 
as described at the end of the section. Using this search window and the 
macroblock, perform a half-pixel motion-vector refinement. The refined motion vector 
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indicates the portion of the search window that is subtracted from the macroblock to 
obtain residual blocks which yield the P-frame macroblock after a DCT operation. 

In the second case, a = 0 and p > 0 so that the upper boundary of the 
macroblock is aligned with a reference DCT block boundary, as shown in Figure 5b. 
Here the macroblock covers six reference DCT blocks. Set a = a + 1 and b = p + 1 to 
define an 18x18 search window as in the first case, then twelve reference DCT 
blocks will be covered by the search window. Even with Liang et al.'s fast algorithm, 
computing the IDCT of all these reference blocks to obtain the pixels in the window is 
expensive. To reduce the complexity, the preferred embodiment refinement methods 
set a = 0 and b = p + 1 thereby obtaining a 16x18 search window whose upper 
boundary aligns with the reference DCT boundary. Now use Liang et al.'s fast 
algorithm to recover the search-window pixels from the six reference DCT blocks 
covered by the window. Next, symmetrically extend the top and bottom of the search 
window to obtain an 18x18 window. Implement the symmetric extension by creating 
new top and bottom rows that are copies of the old top and bottom rows respectively. 

tu:* ~ a „4a M aU m 4.1 a u m :_..» :~ :. .~t.:r.~~i \t : :~ ««iu ~i j.u ~ 

i i no ayi i ii i ion io caici ioiui i icui 11 nv^uc to juoinicu n u 10 n i iayc 10 01 1 iuuu i euui ly n ic 

search window boundaries. Finally, refine the motion vector using the 18x18 search 
window as explained in the first case. 

In the third case, a =0 and p =0 so that the upper and left boundaries of the 
macroblock are aligned with reference DCT block boundaries, as shown in Figure 5c. 
Four reference DCT blocks are covered by the macroblock. On setting a = a + 1 and 
b = p + 1 to define an 18x18 search window as in the first case, 16 reference DCT 
blocks would be covered by the search window. Computing the IDCT of these many 
blocks is prohibitive. Once again, to reduce the complexity, set a = b = 0 to obtain a 
16x16 search window that covers four reference DCT blocks. The search window 
pixels are obtained by applying IDCTs to the four DCT blocks. As in the second 
case, first symmetrically extend the top and bottom of the search window to obtain a 
18x16 search window. Next, symmetrically extend the left and right boundaries of the 
search window by copying the old left-most and right-most columns to obtain the new 
left-most and right-most columns of a 18x18 search window. This search window is 
now used for motion refinement as in the first case. 
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The Liang et al method for obtaining pixel values in corner subblocks of 8x8 
blocks from the 8x8 DCT blocks uses the DCTs of cropping matrices which define 
these corner subblocks and proceeds as follows. 

The operation on each 8x8 block involved in a reference macroblock is either 
(1) obtain all of the pixels in the block or (2) crop the block so that only the pixels 
needed remain. In matrix terminology, the operation of cropping a part of a block can 
be written as matrix multiplications. For instance, cropping the last m rows of an 8x8 
matrix^ can be written asA crop = CiA where C L is the 8x8 matrix with all elements 
equal to 0 except C L Q,j) - 1 for 8-m <j < 7. Similarly, with C R the 8x8 matrix with all 0 
elements except C R (j,j) = 1 for 8-n <j<7, post-multiplication by C R crops the last n 
columns. Thus the operation of cropping the lower right m rows by n columns 
submatrix of A can be written as A crop = ClACr. 

Now denoting the 2-D DCT of A by A means A = 5* AS where S is the 8x8 
DCT transformation matrix. Thus A cr0 p = C^ASCr. And then denoting the product 
ClS 1 as U and CrS 1 as J implies A crop = UAf. Note that the first 8-m rows of U are 
all zeros and the first 8-n rows of Tare all zeros. Thus denoting the mx8 matrix of 
the m nonzero rows of U as U c and the 8xn matrix of the n nonzero rows of T as T c , 
the mxn matrix A cropped consisting of the cropped portion of A is given by A croppe( i =U C A 
Tc. Actually, U c is the last m rows of the inverse 8x8 DCT matrix, and T c is the last n 
rows of the inverse 8x8 DCT matrix 5*. 

And a 1 6x1 6 reference block for the motion vector searching is assembled 
from the pixels of these cropped subblocks. The first case of Figure 5a would have 
one full 8x8 IDCT plus eight cropped blocks. And the IDCTs have fast computation 
methods by using a factorization of the DCT matrix as follows. First, note that the 
8x8 DCT matrix S = DPB1B2MA 1A2A3 where these 8x8 factor matrices are the same 
as those of section 4. 

After applying the foregoing fast DCT on the columns and then applying the 
cropping matrix, only m nonzero rows exist. The computation for the row DCT then 
takes only 42m operations. Also, either A cropped or A croppe d could be computed, so the 
total computation amounts to 336 + 42min(/w,/i) operations. 
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Alternative preferred embodiment methods refine the motion vector for a single 
target NxN block which has an NxN reference block lying within a 2x2 array of 
reference frame NxN blocks; this corresponds to considering just one of the four 
blocks of the macroblocks in the foregoing. Again, if the reference block does not 
align with the blocks of the reference frame, then have a search window by 
expanding the reference block one row/column on each side. But if the reference 
block does align with a block of the reference frame, then again pad on the aligned 
sides to create the search window. 

6. Fast, Drift-Free Transcoding 

The foregoing sections 4 and 5 describe preferred embodiment methods that 
improve the performance of frequency-domain transcoders which are based on the 
framework depicted in Figure 4b. Although these methods make effective use of 
computational and memory resources, frequency-domain motion compensation is 
difficult to implement. Moreover, because frequency-domain motion compensation 
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IDCT/DCT blocks is small. In addition, frequency domain downsampling techniques 
result in frames that differ significantly from the original resolution frames. When 
these altered frames are used for motion compensation, drift artifacts result. Section 
4 proposes a reduced-complexity implementation of Vetro et al.'s intra-refresh 
technique to mitigate drift artifacts. Now this section shall provide computationally 
efficient preferred embodiment transcoding methods that eliminate drift artifacts. 
Section 8 shall demonstrate that the new transcoding methods may be used to 
implement a multi-format transcoder. 

To eliminate the drift artifacts in frequency-domain transcoders based on the 
framework of Figure 4b, first observe that frequency-domain downsampling 
algorithms use frequency-domain operators to perform horizontal and vertical 
averaging followed by decimation. For interlaced video sequences, vertically 
averaged fields may differ significantly from the top and bottom fields. This causes 
severe drift artifacts because motion compensation must be performed specifically 
from the individual fields. Therefore, to eliminate drift, vertical averaging should be 
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avoided. To downsample interlaced frames in the spatial domain without vertical 
averaging, Ghanbari advocates extraction of the top field of each frame followed by 
averaging of even and odd-polyphase components along every row (averaging with 
respect to the column index). 

The preferred embodiment drift-free methods effectively extract the top field in 
the frequency domain followed by horizontal averaging in the spatial domain. The 
Downsample-IDCT stage of the preferred embodiment transcoder illustrated in Figure 
6 performs the method. The Downsample-IDCT stage is an IDCT implementation 
that functions differently for B-frames and for anchor l-/P-frames as follows. 

For B-frames, first downsample frame-DCT blocks vertically with a de- 
interlacing one-dimensional (1-D) IDCT that outputs the top field of each frame-DCT 
block in the spatial-frequency domain (frequency domain for the horizontal 
dimension, spatial domain for the vertical dimension). Section 7 explains an 
implementation of the de-interlacing 1-D IDCT. Next, apply a 1-D IDCT to each of the 
rows of this top field and then horizontally downsampled by either (a) averaging the 

im ino r~i s\ ri r\ It r r\ I** ^\ r\ ***** m n n * « " C A aaL» ma... iU« C. ~~ \ — — /I — \ — I ! — — XI — — 

even- ai iu \j\j\j-\j\jty yi laoc uui i ici no vji cau i i uvv 11 1 n ic iiciu ui \uj ui U|JfJll iy ll ic 

odd-polyphase component of each row. The latter approach to horizontal 
downsampling is faster but may produce slightly perceptible artifacts. 

(For B-frames with field-DCT blocks, the first downsampling is just selection of 
the top field DCT followed by a vertical IDCT and then one of the horizontal 
downsampling methods.) 

For l/P-frames (frame-DCT blocks), apply 2-D IDCT to the DCT-blocks to 
convert to spatial domain, and then horizontally downsample using one of the 
approaches as previously described for the B-frames: either horizontal averaging or 
odd phase discarding. Vertical downsampling for l/P-frames is postponed because 
both top and bottom fields of the l/P-frames are required during the subsequent 
motion compensation. 

(For l/P-frames with field-DCT blocks, apply 2-D IDCT and then a horizontal 
downsampling for both top and bottom field blocks; again postpone vertical 
downsampling until after motion compensation.) 



TI-35495/35498/35514/35515/35536/35537 Page 27 



After the B-frame vertical and horizontal downsampling and the l/P-frame 
horizontal downsampling, perform inverse motion compensation (reconstruction) to 
convert inter blocks to intra blocks as follows. 

For B-frames, only the top fields are motion compensated using either the top 
or bottom field of the horizontally downsampled l/P-frames. 

For P-frames, perform usual motion compensation. Then vertically 
downsample the l/P-frames by discarding the bottom fields of these frames. 

The thus-decoded (reconstructed), spatially-downsampled frames are fed to 
an MPEG-4 encoder which generates the output bitstream using motion estimation 
with re-used motion vectors as illustrated in Figure 6. Following section 7 describes 
the de-interlacing 1-D IDCT that enables efficient B-frame downsampling. Of course, 
bottom fields instead of top fields could be selected. 

7. De-Interlacing 1-D IDCT 

As described in section 6, the frequency-domain transcoding scheme depicted 
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motion compensation is avoided and vertically averaged fields are not used for 
motion compensation. To implement this scheme, the Downsample-IDCT stage must 
directly extract the spatial-domain even polyphase components (top field) from B- 
frame frame-DCT blocks. This extraction is efficient because unwanted polyphase 
components are not computed. The following explains how to implement an IDCT 
method that extracts polyphase components from frame-DCT blocks. Suppose that x 
is a length-A/data sequence and z is the Appoint DCT of x. Denote the even- and 
odd-polyphase components (each length N/2) of x by Xe and Xo, respectively. Let z p 
and z r represent the even- and odd-polyphase components of z in bit-reversed order, 
respectively. In particular, for N = 8: 
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V 






= N/2 







Now, the expression of the iV-point DCT in terms of the M2-point DCT (see Hou 
reference in the background) relates z to x through T(N), an Nx N decimation-in-time 
DCT matrix, as follows: 

T{NI2) T(N/2) 
_KT(Af/2)Q -KT(N/2)Q_ 

where the matrix on the right side is T(N) and thus recursively defines T( ) with initial 
1 1 

cos(;r/4) -cos(;r/4) 

N/2 x NI2 diagonal matrix: diag[cos((4m + 1)n/2iV)] for m = 0, 1 ...... N/2 -1; and 

K = RLR 1 , where R is the bit-reversal permutation matrix; and L is the NI2 x N/2 
lower-triangular matrix: 



T(2) = 



(z 0 is scaled by V2 for notational convenience); Q is a 



L = 
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Matrix inversion (the DCT matrix is orthogonal, so inversion is transposition) shows 
that the polyphase components of x are given by 
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= 2IN 


_ x 0 _ 





T(N/2) QT(N /2)K' 
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Therefore, the even polyphase-component of the data may be directly 
extracted from the DCT block by 

x e = T\N/2) z p + QT(N/2)K l z r 
For N= 8, x e = T l (4) z p + QT^K 1 z r , and the 4-point IDCT, T'(4), requires 4 adds and 
9 multiplies using the Lee decomposition. Multiplication with K requires 6 adds and 5 
shifts while multiplication with Q requires 4 multiplies. Note that the two 4-point 
IDCTs in the equation for* e may be performed in parallel. 

More explicitly for N = 8, the de-interlacing 1-D IDCT may be found as follows. 
First, the 1-D 8-point IDCT, using the abbreviation cN = cos(Nji/16), is: 
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Then consider on!y the even indices of x, and appy the 2k periodicity of the cosine, 
c(N+32) = cN, to have: 
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Note that the V2 has been moved from the matrix into the z 0 component. Next, 
separate the even and odd indices of z to yield: 

"x 0 l ("l c2 c4 c6ir Zo /V2"l [cl c3 c5 c7l[~z,~ 

x 2 l clO c20 c30 z 2 „ c5 cl5 c25 c3 z, 

x 4 l cl8 c4 c22 z 4 c9 c27 cl3 c3l z 5 

_x 6 \ |_l c26 c20 cl4j[ z 6 J [ d3 c7 cl c27 \ [ z i_ 

Using the symmetries of the cosine, cN = c(32-N) and cN = -c(16-N), plus reverse- 
bit ordering the z components gives: 



TI-35495/35498/35514/35515/35536/35537 Page 30 



1 c4 c2 c6 z 0 /V2 c\ c5 c3 c7~| 

1 - c4 - c6 c2 z 4 + y c5 cl - cl c3 z 5 

1 c4 -c2 -c6 z 2 -c7 -c3 c5 cl z 3 

1 -c4 c6 -c2J z 6 |_-c3 cl cl c5 z 7 

The first 4x4 matrix is just the 4-point 1-D IDCT matrix; and as previously noted, the 
second 4x4 matrix factors into the product of three factors: (1) a diagonal matrix of 
cosines, (2) the 4-point 1-D IDCT matrix, and (3) a simple matrix K: 
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Now K = RLR where R is the (symmetric) 4-point bit-reversal permutation matrix, and 
L is the 4x4 lower diagonal matrix of ±1 and ±2 elements which arise from the 
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c(2N+1) = 2c(2N)d -c(2N-1): 
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This factoring provides a fast computation method for the second 4x4 matrix in terms 
of the 4-point 1-D IDCT matrix. 

The foregoing 8-point de-interlacing IDCT applies in the fast, drift-free 
preferred embodiment transcoder of section 6 as follows. 
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First, vertically downsample the B-frame frame-DCT blocks by top-field 
extraction from each 8x8 DCT block using the de-interlacing 1-D IDCT on each of the 
columns; this yields 8-column x 4-row blocks having frequency-domain row index and 
spatial-domain column index. 

Next, perform horizontal downsampling by one of the following two preferred 
embodiment methods: 

(1 ) averaging the even- and odd-polyphase components of each of the four 
top-field rows by first applying an 8-point 1-D IDCT to each of the four top-field rows 
to convert to spatial-domain column index and then averaging the even- and odd- 
polyphase components to yield the downsampled 4x4 in the spatial domain, or 

(2) eliminating the odd-polyphase component of each of the four top-field rows 
by applying the de-interlacing 1-D IDCT to each of the four top-field rows to yield the 
downsampled 4x4 in the spatial domain. As mentioned in section 6, the second 
method is faster but may produce slightly perceptible artifacts around sharp vertical 
edges. 
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may be either a block of pixels (intra-coded) or a block of prediction errors (inter- 
coded). Then the overall downsampling is: 

(a) For B-frames: first apply the de-interlacing 1-D IDCT with respect to the row 
index to each of the columns of Z to extract M*. the 8-column x 4-row top-field of X 
but still with column index still in the frequency domain: 

m k e = T'(4) z\ + QT^K' z\ for k = 0, 1 , .... 7 
where k is the column index. 8x8 Z is the interlace of 8x4 Z p and 8x4 Z r after reverse 
bit-ordering, Z p = [z° p , z\ ], Z r = [z° r , .... z\ ], and = [m° e , m 7 e ]. 

(b) Next, for method (1) first apply 8-point 1-D IDCT to each of the rows of 8x4 M e 
to yield 8x4 top field Xe, and then average pairs of pixels in the rows to yield the 4x4 
downsampling of X. 

For method (2) for each of the four rows of 8x4 Me, apply the de-interlacing 1-D 
IDCT with respect to the column index to directly yield the 4x4 downsampling of X: 
x k 4x4 = = T l (4) n k p + QT'^K 1 n k r for k = 0, 1 , 2, 3 
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where n k p and n k r are the bit-reverse ordered even- and odd-polyphases of n k which 
is the transpose of the k* row of M e and x k 4x4 is the transpose of the kth row of X4 X4 . 

8. Multi-Format Transcoder 

In applications such as video streaming, content is usually available in the 
MPEG-2 interlaced format. However, each end-user may demand that his/her video 
streams should be delivered to him/her in one of several available standards such as 
MPEG-4, H.263, Windows Media Player, or Real Video. To support this requirement, 
a multi-format transcoder that can convert an MPEG-2 bitstream into a user-specified 
standard is critical. This section explains how to efficiently implement a multi-format 
transcoder based on the foregoing Fast, Drift-Free (FDF) transcoder in section 6. 
The multi-format transcoder needs an MPEG-2 decoder and separate encoders for 
each standard that the end-user may demand. Thus, first modify the MPEG-2 
decoder so that it provides de-interlaced, spatially-downsampled raw frames with 
associated motion-vector information as described in section 6 and shown in Figure 
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1. Replace the 2-D IDCT stage of the MPEG-2 decoder with the Downsample- 
IDCT stage used in the fast drift-free transcoder of sections 6-7. 

2. Modify the MPEG-2 decode MC stage so that it motion compensates 
horizontally-downsampled l-/P-frames. For B-frames, perform motion compensation 
on the horizontally-downsampled top field only. After B-frame motion compensation, 
discard the bottom fields of the associated anchor l-/P-frames. 

3. Use one of the methods in Section 2 to estimate motion-vectors for the 
downsampled frames. After modifying the MPEG-2 decoder as described above, the 
ME stage is eliminated from each of the available encoders and replaced with code 
that re-uses the estimated motion vectors provided by the modified MPEG-2 decoder. 
To operate the multi-format transcoder, feed the input content to the modified MPEG- 
2 decoder that now outputs de-interlaced, spatially-downsampled, raw frames along 
with estimated motion-vectors. Then input the frames and motion vectors to the 
appropriate, user-specified encoder that outputs the transcoded bitstream in the user- 
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specified standard. Incorporating the transcoding algorithms in the decoder 
implementation thus provides fast, drift-free multi-format transcoding. 



TI-35495/35498/35514/35515/35536/35537 Page 34 



